// -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
// vi: set et ts=4 sw=2 sts=2:
#ifndef DUNE_LOCALFUNCTIONS_BREZZIDOUGLASMARINI1_QUBE3D_LOCALFINITEELEMENT_HH
#define DUNE_LOCALFUNCTIONS_BREZZIDOUGLASMARINI1_QUBE3D_LOCALFINITEELEMENT_HH

#include <dune/geometry/type.hh>

#include "../common/localfiniteelementtraits.hh"
#include "brezzidouglasmarini1cube3d/brezzidouglasmarini1cube3dlocalbasis.hh"
#include "brezzidouglasmarini1cube3d/brezzidouglasmarini1cube3dlocalcoefficients.hh"
#include "brezzidouglasmarini1cube3d/brezzidouglasmarini1cube3dlocalinterpolation.hh"

namespace Dune
{
  /**
   * \brief First order Brezzi-Douglas-Marini shape functions on hexahedron.
   *
   * \ingroup BrezziDouglasMarini
   *
   * \tparam D Type to represent the field in the domain.
   * \tparam R Type to represent the field in the range.
   */
  template<class D, class R>
  class BDM1Cube3DLocalFiniteElement
  {

  public:
    typedef LocalFiniteElementTraits<
        BDM1Cube3DLocalBasis<D,R>,
        BDM1Cube3DLocalCoefficients,
        BDM1Cube3DLocalInterpolation<BDM1Cube3DLocalBasis<D,R> > > Traits;

    //! \brief Standard constructor
    BDM1Cube3DLocalFiniteElement()
    {}

    /**
     * \brief Make set number s, where 0 <= s < 64
     *
     * \param s Edge orientation indicator
     */
    BDM1Cube3DLocalFiniteElement(int s)
      : basis(s)
      , interpolation(s)
    {}

    const typename Traits::LocalBasisType& localBasis() const
    {
      return basis;
    }

    const typename Traits::LocalCoefficientsType& localCoefficients() const
    {
      return coefficients;
    }

    const typename Traits::LocalInterpolationType& localInterpolation() const
    {
      return interpolation;
    }

    /** \brief Number of shape functions in this finite element */
    unsigned int size () const
    {
      return basis.size();
    }

    static constexpr GeometryType type()
    {
      return GeometryTypes::hexahedron;
    }

  private:
    BDM1Cube3DLocalBasis<D,R> basis;
    BDM1Cube3DLocalCoefficients coefficients;
    BDM1Cube3DLocalInterpolation<BDM1Cube3DLocalBasis<D,R> > interpolation;
  };
} // end namespace Dune
#endif // DUNE_LOCALFUNCTIONS_BREZZIDOUGLASMARINI1_QUBE3D_LOCALFINITEELEMENT_HH
